import java.util.HashMap;

class Solution4 {
    public int findMaxLength(int[] nums) {
        HashMap<Integer,Integer> map = new HashMap<>();
        int sum = 0,ret = 0;
        map.put(0,-1);
        for(int i = 0; i < nums.length; i++) {
            if(nums[i] == 0) {
                nums[i] = -1;
            }
        }
        for(int i = 0; i < nums.length; i++) {
            sum += nums[i];
            if(map.containsKey(sum)) {
                ret = Math.max(ret,i - map.get(sum));
            }else {
                map.put(sum,i);
            }
        }
        return ret;
    }
}